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Amendments to the claims, 

Listing of all claims pursuant to 37 CFR 1.121(c) 

This tinting of claims will replace all prior versions, and listings, of claims m the 
explication; 

1. (Currently Amended) In a database system, a method for constructing an 
optimal query execution plan for executing a query, the method comprising: 

receiving a query specifying at least one join condition between two or more 
database tables; 

identifying each query block within said query, each query block comprising an 
atomic portion of said query; 

creating subplans for each query block based on grouping quantifiers used in outer 
joins of each query block; 

determining at least one favorable access plan for each subplan of each query 
block, said at least one favorable access plan determined based at least in part on 
estimated execution costs; wherein determining at least one favorable access plan for 

sash auhplaa includes generating at least one access plan for different sets of column 

references used in the subplan whose tables are outside the subplan: 

generating an optimal access plan for each query block based upon said at least 

one favorable access plan determined for each subplan; and 

constructing an optimal query execution plan based upon said optimal access plan 

generated for each query block. 

2. (Original) The method of claim 1, wherein said step of identifying each 
query block within said query includes building a query optimization graph for each 
query block. 

3. (Original) The method of claim 1, further comprising: 
generating a query optimization graph for each query block. 

4. (Original) The method of claim 3, wherein said step of generating a query 
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optimization graph includes generating subplans for each query block. 

5. (Original) The method of claim 3, wherein said step of generating a query 
optimization graph includes generating plan nodes for each subplan, said plan nodes for 
joining tables and subplans. 

6. (Original) The method of claim 5, wherein said step of generating a query 
optimization graph includes generating an array of access methods for each plan node. 

7. (Original) The method of claim 5, wherein said step of generating a query 
optimization graph includes generating an array of join methods for each plan node. 

8. (Original) The method of claim 1, wherein a subplan represents a table 
expression of a query block. 

9. (Canceled) 

10. (Currently amended) The method of claim 1, wherein the step of 
determining at least one favorable access plan for each subplan includes the substeps of: 

placing a candidate plan segment in a_the-next position in a current access plan 

being generated, said candidate plan segment representing a particular plan node, access 

method and join method valid at said next position; 

evaluating the current access plan including said candidate plan segment; and 
if the current access plan is less favorable than a favorable access plan previously 

identified, replacing said candidate plan segment with another available candidate plan 

segment and repeating said evaluating substep. 

1 1 . (Original) The method of claim 1 0, wherein a plan node comprises a 
quantifier object. 
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12. (Original) The method of claim 1 1, wherein said quantifier object 
represents a base table. 

13. (Original) The method of claim 11, wherein said quantifier object 
represents a derived table. 

14. (Original) The method of claim 10, wherein a plan node comprises a 
subplan object. 

1 5. (Original) The method of claim 1 4, wherein said subplan object represents 
a join tree of a table expression of a query block. 

16. (Currently amended) The method of claim 10, further comprising; 
if the current access plan is more favorable than a favorable access plan 

previously identified, determining whether the current access plan comprises a complete 
plan; 

if the current access plan is determined not to comprise a complete plan, retaining 
the current access plan and repeating the above substeps for placing a candidate plan 
segment in a&e-next position of the current access plan; and 

otherwise, if the current access plan is determined to be a complete plan, retaining 
the current access plan as a favorable access plan and repeating the above substeps to 
consider other available alternatives to the current access plan while alternatives are 
available. 

17. (Original) The method of claim 10, further comprising: 

generating a property vector for said current access plan including said candidate 
plan segment. 

18. (Original) The method of claim 1 7, wherein said property vector includes 
estimated execution costs for said current access plan. 
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19. (Previously presented) The method of claim 17, wherein said property 
vector includes pipeline characteristics for said current access plan, wherein said pipeline 
characteristics describe how results are computed by said current access plan, 

20. (Original) The method of claim 17, wherein said property vector includes 
order properties for said current access plan. 

21 . (Original) The method of claim 1, wherein said step of generating at least 
one favorable access plan for each subplan of each query block includes using a left-deep 
join enumeration strategy. 

22. (Previously presented) The method of claim 1, wherein said step of 
generating at least one favorable access plan for each subplan of each query block 
includes starting with innermost nested subplans of each query block. 

23. (Original) The method of claim 1, wherein said step of generating at least 
one favorable access plan for each subplan includes evaluating execution costs of partial 
access plans and pruning partial access plans less favorable than previously generated 
complete access plans. 

24. (Original) A computer-readable medium having computer-executable 
instructions for performing the method of claim 1 , 

25. (Previously presented) The method of claim I, further comprising: 
downloading a set of computer-executable instructions for performing the method 

of claim 1. 

26. (Currently amended) In a database system, a method for generating a bushy 
trees during optimization of a database query, the method comprising: 
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receiving a database query specifying at least one join condition between two or 
more database tables; 

identifying each query block within said query, said query block comprising an 
atomic block of said query; 

building a query optimization graph for each query block, said query optimization 
graph including plan nodes representing subplans and quantifiers of each query block; 
wherein said subplans group quantifiers used in outer joins of each query block; 

constructing a join tree for each subplan based upon selecting access methods, 
join methods, and join order for plan nodes of said query optimization graph having 
favorable execution costs; 

constructing an optimal access plan for each query block based upon said join tree 
constructed for each subplan; wherein constructing an optimal access plan includes 
constructing at least one access plan for different sets of column references used in a 

subplan whose tables are outside the subplan; and 

generating a bushy execution tree based upon the optimal access plan determined 
for each query block. 

27. (Original) The method of claim 26, wherein a query block comprises a 
selected one of a main block of a Structured Query Language (SQL) statement, a main 
block of a derived table, a main block of a view, a main block of a subquery used in a 
SQL statement, a derived table, and a view. 

28. (Original) The method of claim 26, wherein said step of building said 
query optimization graph includes modeling left outer joins, right outer joins, and full 
outer joins as subplans which correspond to null-supplying sides of an outer join. 

29. (Original) The method of claim 26, wherein said step of generating a query 
optimization graph includes generating an array of access methods for each plan node. 

30. (Original) The method of claim 26, wherein said step of generating a query 
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optimization graph includes generating an array of join methods for each plan node. 

31. (Original) The method of claim 26, wherein said step of constructing 
bushy join trees for each subplan includes using a left-deep enumeration strategy. 

32. (Original) The method of claim 26, wherein said step of constructing a join 
tree includes evaluating execution costs of a candidate plan segment to be added to said 
join tree being constructed. 

33. (Original) The method of claim 32, wherein said candidate plan segment 
comprises a selected plan node together with an access method and a join method. 

34. (Original) The method of claim 26, wherein said bushy tree comprises a 
processing tree having composite relations for left and right children of join nodes. 

35. (Original) The method of claim 26, wherein said step of constructing an 
optimal bushy access plan includes evaluating execution costs of partial access plans 
enabling earlier pruning of unfavorable access plans. 

36. (Currently amended) In a database system, a method for optimizing 
execution of a query, the method comprising: 

receiving a query specifying selection of data from a plurality of database tables; 

enumerating candidate plan segments for inclusion in an access plan for selecting 
data specified by the query, said candidate plan segments representing alternative 
strategies for joining relations and selecting data; 

for each query block comprising an atomic portion of said query, wherein query 
blocks are associated with subplans that are created based on grouping quantifiers used in 
outer joins of each query block f determining an optimal access plan for each query block. 
wherein determining an optimal access plan for each emery block includes determininu an 

optimal access plan for each subplan of each query block, by performing the substeps of: 
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placing a candidate plan segment in a partial access plan being generated for said 
query block; 

evaluating said partial access plan including said candidate plan segment; 

if said partial access plan is less favorable than a complete access plan previously 
identified for said query block, pruning said candidate plan segment; 

otherwise, adding an additional candidate plan segment to said partial access plan 
and repeating the above steps until a complete access plan for said query block is 
generated; 

retaining a complete access plan if it is more favorable than other complete access 
plans previously generated for the query block; and 

otherwise pruning a complete access plan which is less favorable than other 
complete access plans; and 

generating a query execution plan based upon the optimal access plan determined 
for each query block. 

37. (Original) The method of claim 36, wherein each said candidate plan 
segment comprises a plan node, an access method and a join method. 

38. (Previously presented) The method of claim 37, wherein a plan node 
comprises a subplan object created based on grouping quantifiers used in outer joins of 
said queiy block. 

39. (Original) The method of claim 37, wherein a plan node comprises a 
quantifier object. 

40. (Original) The method of claim 36, where said substep of evaluating said 
partial access plan includes comparing estimated execution costs of said partial access 
plan to estimated execution costs of a complete access plan previously generated for said 
query block. 
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4 1 . (Original) The method of claim 36, where said substep of evaluating said 
partial access plan before a complete access plan is generated enables early pruning of 
less favorable access plans. 

42. (Canceled) 

43. (Currently amended) The method of claim 36 claim 4 2 . wherein said step 
of generating an optimal access plan for each subplan of each query block includes 
starting with innermost nested sub plans of each query block. 

44. (Original) The method of claim 36, wherein said step of generating an 
optimal access plan for each query block includes using a left-deep join enumeration 
strategy. 

45. (Original) The method of claim 36, further comprising: 
generating a property vector for each said partial access plan. 

46. (Original) The method of claim 45, wherein said property vector includes 
estimated execution costs for a candidate plan segment. 

47. (Original) The method of claim 45, wherein said evaluating substep 
includes comparing said property vector of said partial access plan to a property vector of 
a complete access plan previously generated for said query block. 

48. (Original) The method of claim 45, further comprising: 

retaining a property vector of a complete plan generated for a query block if said 
complete plan is more favorable than any other complete access plan previously 
generated for the query block. 

49. (Original) The method of claim 36, wherein said substep of pruning said 
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candidate plan segment includes replacing said candidate plan segment with another 
available candidate plan segment and repeating said evaluating substep. 
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